# Test Planning for Honors Design Lab AHB Convolver

Aiden Gonzalez and Yug Rao

April 18th, 2021

# **Top Level Design Tests:**

| Module Tested | Feature Tested             | Test Name                       | Inputs                                                                                                                             | Outputs                                                                                                                   |
|---------------|----------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| AHB Convolver | Reset                      | Power On / Reset                | Reset                                                                                                                              | All zeros                                                                                                                 |
| AHB Convolver | Coefficient<br>Loading     | Coefficient<br>Loading Test     | Write to all three coefficient registers, then set coefficient load bit                                                            | Modwait is asserted during coefficient loading, then deasserted, and values are properly stored in coefficient register   |
| AHB Convolver | Sample Loading             | Sample Loading<br>Test          | From idle, write to sample register then set new_sample bit. Repeat two more times to complete initial load.                       | Modwait asserted during each load, then deasserted and sample_stream asserted to indicate ready for column streaming      |
| AHB Convolver | Streaming /<br>Convolution | Streaming /<br>Convolution Test | From convolve state, repeatedly write new sample and assert new_sample bit. After many convolutions, attempt to read some results. | Alternating between sample_stream and modwait.                                                                            |
| AHB Convolver | Sample Loading             | New Sample Row<br>Loading Test  | From convolve state, assert new_row bit and follow three sample load procedure from before.                                        | Modwait asserted during each load, then deasserted and sample_stream asserted to indicate ready for more column streaming |
| AHB Convolver | Sample Complete            | Sample Complete<br>Test         | After max number of convolutions (with new rows at appropriate intervals), read results                                            | Correct result values in sequence                                                                                         |

# **Multiplier/Adder Tree Tests:**

| Module Tested | Feature Tested | Test Name                          | Inputs                            | Outputs                                                                      |
|---------------|----------------|------------------------------------|-----------------------------------|------------------------------------------------------------------------------|
| Mult/Add Tree | Multiply/Sum   | Zeros                              | All zeros                         | All zeros                                                                    |
| Mult/Add Tree | Multiply/Sum   | Small Coefficients / Small Samples | Small coefficients, small samples | Correct sum of multiplied values                                             |
| Mult/Add Tree | Multiply/Sum   | Small Coefficients / Large Samples | Small coefficients, large samples | Correct sum of multiplied values                                             |
| Mult/Add Tree | Multiply/Sum   | Large Coefficients / Small Samples | Large coefficients, small samples | Correct sum of multiplied values                                             |
| Mult/Add Tree | Multiply/Sum   | Large Coefficients / Large Samples | Large coefficients, large samples | Correct sum of multiplied values                                             |
| Mult/Add Tree | Multiply/Sum   | Max                                | Max coefficients, max samples     | 2025                                                                         |
| Mult/Add Tree | Result Ready   | Result Ready Test                  | Series of calculations            | Result_ready pulsed for 1 clock period 1 clock period after each calculation |

## **Sample Shift Register Tests:**

| Module Tested            | Feature Tested | Test Name              | Inputs                                              | Outputs                                                               |
|--------------------------|----------------|------------------------|-----------------------------------------------------|-----------------------------------------------------------------------|
| Sample Shift<br>Register | Reset          | Power On / Reset       | Reset                                               | Empty Registers (Zeros outputted)                                     |
| Sample Shift<br>Register | Shift Enable   | Enable Test            | No enable and various samples                       | Zero output steady                                                    |
| Sample Shift<br>Register | Input Shifting | Single Sample<br>Shift | Enable and one sample, followed by two zero samples | Correct sequence of values corresponding to single input              |
| Sample Shift<br>Register | Input Shifting | Three sample shift     | Enable and three large samples                      | Correct sequence of values outputted corresponding to sequenced input |

## **Coefficient Register Tests:**

| Module Tested           | Feature Tested         | Test Name                       | Inputs                                                                               | Outputs                                                              |
|-------------------------|------------------------|---------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| Coefficient<br>Register | Reset                  | Power On / Reset                | Reset                                                                                | Empty Registers (Zeros outputted)                                    |
| Coefficient<br>Register | Coefficient<br>Loading | Coefficient Load<br>Enable Test | Sequence of coefficients sent to 0 index register with coeff_ld enabled and disabled | Correct sequence of values based on enable status                    |
| Coefficient<br>Register | Coefficient<br>Loading | Coefficient<br>Addressing Test  | Coeff_ld and various coefficient values / addresses                                  | Correct sequence of values in corresponding 12 bit regions of output |

# FIFO Result Shift Register Tests:

| Module Tested | Feature Tested    | Test Name              | Inputs                                                                       | Outputs                                                                                       |
|---------------|-------------------|------------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| Result FIFO   | Reset             | Power On / Reset       | Reset                                                                        | Empty Registers<br>(Zeros outputted)                                                          |
| Result FIFO   | Write Enable      | Wenable Test           | Sequence of result_in values and pulsing wenable to ensure correct operation | Correct sequence of values read out                                                           |
| Result FIFO   | Read Enable       | Renable Test           | Write sequence of values first, then read by pulsing renable                 | Correct sequence of valued read out, after pulsing renable for one clock cycle for each value |
| Result FIFO   | Writing / Reading | Result Writing<br>Test | Long sequence of wenable pulses and result_in values.                        | Correct sequence of values when read out (FIFO order)                                         |
| Result FIFO   | Full              | Write when Full        | Write until full,<br>then attempt to<br>write again                          | Full output, then no response to write attempt                                                |
| Result FIFO   | Empty             | Read when Empty        | Attempt read after reset                                                     | Empty output,<br>then no response<br>to read attempt                                          |

#### **Convolver Controller Tests:**

| Module Tested | Feature Tested                  | Test Name                | Inputs                                                                                       | Outputs                                                                                                                           |
|---------------|---------------------------------|--------------------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Controller    | Reset                           | Power On / Reset         | Reset                                                                                        | Empty Registers (Zeros outputted)                                                                                                 |
| Controller    | Coefficient<br>Loading          | Coefficient Load<br>Test | coeff_load_en                                                                                | Correct sequence of modwait, coeff_ld, and coeff_sel outputs to load all three coefficient columns. Also correct modwait behavior |
| Controller    | Sample Loading                  | Sample Load Test         | From idle, assert sample_load_en and follow procedure for initial sample load                | Modwait and sample shift pulsed according to moore state transition diagram                                                       |
| Controller    | Sample Streaming and Convolving | Sample Streaming<br>Test | After initial sample loading, input a new sample column and assert sample_load_en repeatedly | Alternation<br>between<br>convolve_en/sam<br>ple_stream and<br>modwait/sample_<br>shift                                           |
| Controller    | Sample Loading                  | New Sample Row<br>Test   | In convolve state,<br>assert, new_row<br>and follow<br>procedure for<br>initial sample load  | Modwait and sample shift pulsed according to moore state transition diagram                                                       |
| Controller    | Sample Complete                 | Sample Complete<br>Test  | From convolve state, assert new_row and sample_load_en                                       | Return to idle state (no outputs)                                                                                                 |

#### **AHB "Slave" Interface Tests:**

| Module Tested | Feature Tested                  | Test Name                                    | Inputs                                                                                    | Outputs                                                                              |
|---------------|---------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| AHB "Slave"   | Reset                           | Power On /<br>Reset                          | Reset                                                                                     | Empty Registers<br>(Zeros outputted)                                                 |
| AHB "Slave"   | Status Register                 | Status Write Test                            | Attempt AHB write of value to status register                                             | Error condition<br>(HRESP)                                                           |
| AHB "Slave"   | Status Register                 | State Read Test                              | Assert modwait<br>and<br>sample_stream<br>high and low                                    | Correct output from status register on HRDATA (particularly for bits 0 and 8)        |
| AHB "Slave"   | FIFO Result<br>Register         | FIFO Write Test                              | Attempt AHB write of value to result register                                             | Error condition<br>(HRESP)                                                           |
| AHB "Slave"   | FIFO Result<br>Register         | FIFO Read Test                               | Attempt AHB read of value from result register while asserting a value on result_in       | Read_enable<br>followed by the<br>value in result_in<br>being outputted<br>on HRDATA |
| AHB "Slave"   | New Sample<br>Column Register   | Sample Write<br>Test                         | Attempt AHB write to new sample register                                                  | Sample value<br>written to register<br>(no output)                                   |
| AHB "Slave"   | New Sample<br>Column Register   | Sample Read<br>Test                          | Attempt AHB read from new sample register                                                 | Sample value outputted on HRDATA                                                     |
| AHB "Slave"   | Coefficient<br>Column Registers | Coefficient Write<br>Test                    | Attempt AHB write<br>to all three<br>coefficient registers<br>(separate<br>transactions)  | Coefficient Values written to corresponding registers (no output)                    |
| AHB "Slave"   | Coefficient<br>Column Registers | Coefficient Read<br>Test                     | Attempt AHB read<br>from all three<br>coefficient registers<br>(separate<br>transactions) | Coefficient values outputted on HRDATA                                               |
| AHB "Slave"   | Command/Control<br>Register     | Command Write<br>Test (Load<br>Coefficients) | Attempt AHB write<br>to bit 0, then<br>manipulate<br>coeff_sel                            | Coeff_load_en is asserted and coeff_out corresponds to coeff_sel input               |

| AHB "Slave" | Command/Control<br>Register | Command Write<br>Test (Load New<br>Column | Attempt AHB write to bit 1                      | Sample_load_en is asserted                    |
|-------------|-----------------------------|-------------------------------------------|-------------------------------------------------|-----------------------------------------------|
| AHB "Slave" | Command/Control<br>Register | Command Write<br>Test (Start New<br>Row)  | Attempt AHB write to bit 2                      | New_row is asserted                           |
| AHB "Slave" | Command/Control<br>Register | Command Write<br>Test (Sample<br>Done)    | Attempt AHB write to bits 1 and 2               | Sample_load_en<br>and new_row are<br>asserted |
| AHB "Slave" | Command/Control<br>Register | Command Read<br>Test                      | Attempt AHB read from command /control register | Correct value is outputted on HRDATA          |

